Docker এবং Kubernetes দিয়ে Microservices ডেপ্লয়

Microsoft Technologies - ডট নেট কোর (Dot.Net Core) Microservices Architecture এবং Dot.Net Core |
188
188

মাইক্রোসার্ভিস আর্কিটেকচার (Microservices Architecture) একটি অ্যাপ্লিকেশনকে ছোট, স্বাধীন এবং মডুলার সার্ভিসগুলোর মধ্যে ভাগ করে, যা পৃথকভাবে ডেভেলপ, ডিপ্লয় এবং স্কেল করা যায়। এই আর্কিটেকচারটি বিশেষভাবে উপকারী যখন আপনি বৃহৎ এবং জটিল অ্যাপ্লিকেশন তৈরি করছেন। Docker এবং Kubernetes এই মডুলার অ্যাপ্লিকেশনগুলোকে সহজে ডিপ্লয়, ম্যানেজ এবং স্কেল করতে সাহায্য করে।

Docker একটি কন্টেইনারাইজেশন প্ল্যাটফর্ম, যা অ্যাপ্লিকেশন এবং তার নির্ভরশীলতাগুলোকে একে অপরের থেকে আলাদা করে এবং একক ইউনিট হিসেবে ডিপ্লয় করা সম্ভব করে। অন্যদিকে, Kubernetes একটি কন্টেইনার অর্কেস্ট্রেশন টুল, যা কন্টেইনারাইজড অ্যাপ্লিকেশনগুলোকে স্বয়ংক্রিয়ভাবে ডিপ্লয়, স্কেল এবং ম্যানেজ করতে ব্যবহৃত হয়।


Docker দিয়ে Microservices ডেপ্লয়

Docker একটি কন্টেইনার প্রযুক্তি যা অ্যাপ্লিকেশনগুলোকে লাইটওয়েট, পোর্টেবল এবং স্কেলেবল ইউনিট হিসেবে তৈরি করতে সাহায্য করে। মাইক্রোসার্ভিস অ্যাপ্লিকেশনে, প্রতিটি সার্ভিস সাধারণত একটি আলাদা Docker কন্টেইনারে চলে, যা কেবল ঐ সার্ভিসের জন্য প্রয়োজনীয় ডিপেন্ডেন্সি এবং কনফিগারেশন ধারণ করে। এটি আপনার অ্যাপ্লিকেশনগুলোর একাধিক সার্ভিসকে বিভিন্ন পরিবেশে (যেমন, ডেভেলপমেন্ট, টেস্টিং, প্রোডাকশন) একে অপরের থেকে আলাদা ও স্বতন্ত্রভাবে চালাতে সহায়তা করে।

ডকার কন্টেইনারের সুবিধা:

  1. পোর্টেবিলিটি: Docker কন্টেইনারটি এক পরিবেশ থেকে আরেক পরিবেশে একদম সহজে মুভ করা যায়।
  2. আনুষ্ঠানিকতা: সার্ভিসগুলো একে অপরের থেকে আলাদা থাকায় সেগুলোকে নিয়ন্ত্রণ করা, স্কেল করা এবং আপডেট করা সহজ হয়।
  3. ইনফ্রাস্ট্রাকচার অ্যাবস্ট্রাকশন: Docker কন্টেইনারে সার্ভিস চালানোর জন্য সরাসরি হোস্ট মেশিনের ইনফ্রাস্ট্রাকচার নির্ভর করতে হয় না, ফলে যেকোনো হোস্ট সিস্টেমে কন্টেইনার রান করতে সক্ষম হয়।

Docker দিয়ে মাইক্রোসার্ভিস ডিপ্লয় করার ধাপ:

  1. Dockerfile তৈরি করুন: প্রতিটি মাইক্রোসার্ভিসের জন্য একটি Dockerfile তৈরি করুন, যেখানে সার্ভিসটি কিভাবে ডিপ্লয় হবে, তার জন্য সব নির্দেশনা থাকবে।

    উদাহরণস্বরূপ:

    # Use a base image with .NET SDK
    FROM mcr.microsoft.com/dotnet/aspnet:6.0 AS base
    WORKDIR /app
    EXPOSE 80
    
    # Use a build image with .NET SDK to build the app
    FROM mcr.microsoft.com/dotnet/sdk:6.0 AS build
    WORKDIR /src
    COPY ["MyMicroservice/MyMicroservice.csproj", "MyMicroservice/"]
    RUN dotnet restore "MyMicroservice/MyMicroservice.csproj"
    COPY . .
    WORKDIR "/src/MyMicroservice"
    RUN dotnet build "MyMicroservice.csproj" -c Release -o /app/build
    
    # Publish the app to the /app/publish directory
    RUN dotnet publish "MyMicroservice.csproj" -c Release -o /app/publish
    
    # Copy the build app and set entry point
    FROM base AS final
    WORKDIR /app
    COPY --from=build /app/publish .
    ENTRYPOINT ["dotnet", "MyMicroservice.dll"]
    
  2. Docker Image Build করুন: Dockerfile তৈরি করার পর, সেই ফাইল থেকে একটি Docker ইমেজ তৈরি করুন:

    docker build -t my-microservice .
    
  3. Docker কন্টেইনার রান করুন: তৈরি করা Docker ইমেজটি দিয়ে কন্টেইনার রান করুন:

    docker run -d -p 8080:80 my-microservice
    

Kubernetes দিয়ে Microservices ডেপ্লয়

Kubernetes হল একটি কন্টেইনার অর্কেস্ট্রেশন প্ল্যাটফর্ম যা একাধিক কন্টেইনারের ব্যবস্থাপনা, স্কেলিং, অটো-হেলথ চেক, রোলিং আপডেট এবং ডিপ্লয়মেন্ট অটোমেশন সহজ করে। Kubernetes কন্টেইনারের মধ্যে একটি সহজ অভ্যন্তরীণ নেটওয়ার্ক তৈরি করে এবং সার্ভিসগুলোর মধ্যে যোগাযোগের ব্যবস্থা সহজ করে।

Kubernetes দিয়ে Microservices ডিপ্লয় করার সুবিধা:

  1. অটো স্কেলিং: Kubernetes স্বয়ংক্রিয়ভাবে কন্টেইনারের সংখ্যা বৃদ্ধি বা হ্রাস করতে পারে, নির্ভর করে ট্রাফিকের উপর।
  2. লিড রিকভারি: যদি কোনো কন্টেইনার ফেল হয়, Kubernetes স্বয়ংক্রিয়ভাবে সেই কন্টেইনারটি পুনরায় শুরু করতে পারে।
  3. ডিপ্লয়মেন্ট ম্যানেজমেন্ট: Kubernetes বিভিন্ন পরিবেশে অ্যাপ্লিকেশনগুলো অটোমেটিক্যালি ডিপ্লয় করতে পারে, এবং রোলিং আপডেটের মাধ্যমে নতুন সংস্করণ আপলোড করতে সহায়তা করে।

Kubernetes দিয়ে মাইক্রোসার্ভিস ডিপ্লয় করার ধাপ:

  1. Kubernetes Deployment YAML ফাইল তৈরি করুন: Kubernetes এ মাইক্রোসার্ভিস ডিপ্লয় করার জন্য একটি Deployment YAML ফাইল তৈরি করুন। এই ফাইলটি Kubernetes কে নির্দেশ দিবে কিভাবে আপনার কন্টেইনারগুলি রান করবে এবং কিভাবে তারা ইন্টারঅ্যাক্ট করবে।

    উদাহরণস্বরূপ:

    apiVersion: apps/v1
    kind: Deployment
    metadata:
      name: my-microservice-deployment
    spec:
      replicas: 3
      selector:
        matchLabels:
          app: my-microservice
      template:
        metadata:
          labels:
            app: my-microservice
        spec:
          containers:
            - name: my-microservice
              image: my-microservice:latest
              ports:
                - containerPort: 80
    
  2. Kubernetes Service YAML ফাইল তৈরি করুন: Service YAML ফাইল তৈরি করে আপনার কন্টেইনারের সাথে বাইরের যোগাযোগ প্রতিষ্ঠা করুন।

    apiVersion: v1
    kind: Service
    metadata:
      name: my-microservice-service
    spec:
      selector:
        app: my-microservice
      ports:
        - protocol: TCP
          port: 80
          targetPort: 80
      type: LoadBalancer
    
  3. Deployment এবং Service Kubernetes এ ডিপ্লয় করুন: Kubernetes ক্লাস্টারে YAML ফাইলটি ব্যবহার করে ডিপ্লয় করুন:

    kubectl apply -f my-microservice-deployment.yaml
    kubectl apply -f my-microservice-service.yaml
    
  4. Kubernetes Cluster এ Microservices Monitor করুন: Kubernetes এর kubectl কমান্ড দিয়ে আপনি আপনার ডিপ্লয়মেন্টের অবস্থা মনিটর করতে পারেন:

    kubectl get pods
    kubectl get services
    

সারাংশ

Docker এবং Kubernetes একসাথে মাইক্রোসার্ভিস অ্যাপ্লিকেশন ডিপ্লয় করার জন্য একটি শক্তিশালী টুলচেইন প্রদান করে। Docker কন্টেইনারগুলোর মাধ্যমে প্রতিটি মাইক্রোসার্ভিসকে স্বতন্ত্র ও পোর্টেবল ইউনিটে পরিণত করে, এবং Kubernetes সেগুলোকে স্কেল, ম্যানেজ এবং অটোমেটিকভাবে ডিপ্লয় করতে সাহায্য করে। এটি মাইক্রোসার্ভিস আর্কিটেকচারের মূল সুবিধাগুলোর মধ্যে একটি—যেখানে সার্ভিসগুলো স্বাধীনভাবে ডেভেলপ, ডিপ্লয় এবং স্কেল করা যায়।

common.content_added_by
টপ রেটেড অ্যাপ

স্যাট অ্যাকাডেমী অ্যাপ

আমাদের অল-ইন-ওয়ান মোবাইল অ্যাপের মাধ্যমে সীমাহীন শেখার সুযোগ উপভোগ করুন।

ভিডিও
লাইভ ক্লাস
এক্সাম
ডাউনলোড করুন
Promotion